js:关于scrollHeight和scrollTop取值为0的问题 |
您所在的位置:网站首页 › vue scrolltop一直为0 › js:关于scrollHeight和scrollTop取值为0的问题 |
基础
obj.offsetTop 指 obj 距离上方或上层控件的位置,整型,单位像素。
obj.offsetLeft 指 obj 距离左方或上层控件的位置,整型,单位像素。
obj.offsetWidth 指 obj 控件自身的宽度,整型,单位像素。
obj.offsetHeight 指 obj 控件自身的高度,整型,单位像素。(clientHeight + 滚动条 + 边框)
obj.scrollHeight网页内容的高度,最小值是clientHeight。
offsetTop与style.top的区别 offsetTop 返回的是数字,而 style.top 返回的是字符串,除了数字外还带有单位:px。 offsetTop 只读, style.top 可读写。 如果没有给 HTML 元素指定过 top 样式,则 style.top 返回的是undefined。(也就是说内联样式与外联样式和内嵌样式都没有设置style.xx则js是无法设置该元素相应的的style.xx) 问题及解决所以document.body.scrollHeight与document.documentElement.scrollHeight都是获取网页页面内容的高。 但是今天我发现使用他们时并没有达到我想要的效果,仔细查看发现firefox下document.body.scrollHeight的值始终是0,下面是测试: height&top firefox下: firefox Chrome下 chrome IE11下 IE11 可以发现chrome对document.documentElement.scrollHeight&document.documentElement.scrollTop是不能识别的,而firefox和IE11不能识别document.body.scrollHeight&document.body.scrollTop,所以要考虑的网页的兼容性,建议两种获取方法都要写在代码里。另外我也测试clientXxx,写在总结里吧。 总结在js中需要取scrollHeight值和scrollTop值时,我们需要使用: var oHeight=document.body.scrollHeight==0?document.documentElement.scrollHeight:document.body.scrollHeight; var oTop=document.body.scrollTop==0?document.documentElement.scrollTop:document.body.scrollTop;关于scrollWidth: var oWidth=document.body.scrollWidth;&var oWidth=document.documentElement.scrollWidth;都不会出现兼容问题 取clientXxx值只能:var wWidth=document.documentElement.clientXxx; 2018/5/2更新... 随着浏览器的升级,当前可用情况也有了一些变化。 粗略测试当前只需要对scrollTop作为零判断,scrollHeight / clientXxx都可以通过document和body取得。 |
今日新闻 |
推荐新闻 |
CopyRight 2018-2019 办公设备维修网 版权所有 豫ICP备15022753号-3 |